环境说明:
操作系统:Windows Server 2012 R2
PHP版本:php-5.6.35-Win32-VC11-x64
下载地址:https://windows.php.net/downl...
(注:VC11 x64 Thread Safe)
MySQL版本:mysql-5.7.11-winx64.zip
下载地址:http://dev.mysql.com/get/Down...
Apache版本:httpd-2.4.33-o102o-x64-vc14-r2
下载地址:http://de.apachehaus.com/down...
相关运行库和软件下载
1. Visual C++ Redistributable for Visual Studio 2012 Update 4(x64)下载地址(安装PHP需要此插件):
地址:http://download.microsoft.com...
2. Visual C++ Redistributable for Visual Studio 2012 Update 4(x86)(安装PHP需要此插件):
地址:http://download.microsoft.com...
3.Visual C++ Redistributable for Visual Studio 2015(x86和x64)(安装Apache需要此插件):
地址:https://www.microsoft.com/en-...
4.Microsoft Visual C++ 2010 可再发行组件包 (x86)下载地址(安装MySQL需要此插件):
地址:http://download.microsoft.com...
一、MYSQL
(一)安装
1.下载mysql
zip版本mysql不需要运行可执行文件,解压即可,下载zip版本mysql
msi版本mysql双击文件即可安装,相对简单,本文不介绍此版本安装
2.配置环境变量
打开环境变量配置页面(winserver服务器环境变量位置:服务器管理器->本地服务器->计算机名称->高级->环境变量),在系统变量path后面添加mysql bin文件路径,例如:;C:mysqlbin
3.配置mysql
mysql配置文件my-default.ini在项目根目录下,修改成my.ini
配置文件修改方式如下:
basedir = C:\mysql
(mysql根目录)datadir = C:\mysql\data
(mysql数据库存放目录)port = 3306
(mysql对外开放端口,默认3306,可修改)
4.启动mysql
a. 启动cmd(win+R)
b. 进入mysql的bin目录,命令:cd C:mysqlbin
c. 安装mysql服务,命令:mysqld -install,返回结果:Service successfully installed。快捷键win+r,执行services.msc查看服务,看看mysql服务是否已出现
d. 初始化mysql并指定超级用户密码为空,命令:mysqld --initialize-insecure --user=mysql
e. 启动mysql服务,命令:net start mysql
5.问题及解决方案
a. net start mysql
启动mysql服务时,启动失败,返回结果:发生系统错误2,系统找不到指定文件
执行services.msc
查看服务mysql,在服务上右键->属性->常规,查看可执行路径是否正确,若不正确,可能是启动mysql时未切换盘符导致的,执行命令:mysqld -remove
,移除mysql服务然后重新安装
b. net start mysql启动mysql服务时,启动失败,返回结果:mysql服务无法启动,服务没有报告任何错误,请键入NET HELPMSG ** 以获得更多的帮助
到之前配置的datadir路径中查找一个后缀名为.err的文件(若指定的路径不存在找不到.err文件,应先创建路径,然后启动服务),此文件记录mysql错误日志。若日志中记录的错误为:[ERROR] Can't open the mysql. Please run mysql_upgrade to create it,则先清空datadir中的文件,然后执行命令初始化:mysqld --initialize-insecure --user=mysql
(二)登录用户管理及密码修改
登录mysql
a. 启动cmd
b. 登录,命令:mysql -u root -p
,因为初始化超级用户时未指定密码(可随机生成初始密码),因此默认密码为空,输入密码步骤直接回车,看到欢迎信息:Welcome to the MySQL monitor
修改root用户密码
a. 查看所有初始数据库,其中mysql库就是刚刚初始化的库,其中包含用户登录信息
b. 选中数据库,命令:use mysql
;
c. 查看用户现有用户及密码,注意:mysql5.7用户密码字段为authentication_string,5.7以前为password
d. 修改root密码
格式:mysql> set password for 用户名@localhost = password('新密码');
例子:mysql> set password for root@localhost = password('123456')
; 上面例子将用户root的密码更改为123456;
e. 忘记root密码情况
关闭正在运行的MySQL服务。
打开DOS窗口,转到mysqlbin目录。
输入mysqld --skip-grant-tables 回车。--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。
再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),输入mysql回车,如果成功,将出现MySQL提示符 >。
连接权限数据库: use mysql; 。
改密码:update user set password=password("root") where user="root";
(别忘了最后加分号) 。
刷新权限(必须步骤):flush privileges;
。
退出 quit
。
重启mysql服务,使用用户名root和刚才设置的新密码root登录就ok了;
(三)开启远程访问
1.查询用户host
host为localhost表示只允许本地登录,host为ip表示为只允许指定ip用户登录,host为%为允许任意ip用户登录
2.新建允许远程链接mysql数据库的用户
grant all on . to sa@'%' identified by '123456' with grant option;
flush privileges;
创建一个登录名为sa,密码为123456供任意ip访问的用户(%可用具体ip替代)
二、PHP
1.把下载下来的php解压,到 c:php;
2.在系统环境变量Path中添加 ;C:\php;C:\php\ext
, 重启后生效;
3.进入PHP安装目录,找到 php.ini-development(生产环境用php.ini-production) 文件并复制一份到当前目录,重命名为 php.ini;
4.修改php配置文件php.ini
修改ext文件夹的路径(extension_dir="C:/php/ext"
);
5.要在 php.ini 中启用某扩展库,需要去掉该行 extension=php_*.dll
前的注释符号,这里需要启用 php_mbstring,php_openssl 扩展库等;
三、Apache
1.把下载下来的Apache压缩包解压到c:Apache24\
2.修改Apache24confhttpd.conf 文件
把ServerRoot这行修改为 ServerRoot "c:/Apache24"
, 双引号之间的就是你的apache放置的位置
3.新建wamp在“c:wamp”目录下新建文件夹“www”,把你网站的html文件和php文件放入该文件夹。
修改Apache24confhttpd.conf 文件
把DocumentRoot按照下面的内容修改(注意斜杠的正反):
DocumentRoot "c:/wamp/www"
<Directory "c:/wamp/www">
4.在httpd.conf 文件中添加下面几行,增加对php5的支持:
# php5 support
LoadModule php5_module D:/php/php5apache2_4.dll
AddType application/x-httpd-php .php .html .htm
# configure the path to php.ini
PHPIniDir "c:/php"
5.保存httpd.conf文件, 重启Apache服务。
重启方式1:httpd -k restart
重启方式2:在桌面开始菜单中选择运行,输入services.msc
找到apache 右键重启就可以了
ps:通过命令进行操作之前,需要将apache安装目录下的bin目录加入计算机的环境变量的path里面。httpd -k start(stop/restart)
来启动和停止apache服务器
小技巧:在cmd窗口中输入:
c:\apache24\bin\httpd.exe -k install
这句可以把apache添加到系统服务里去。
大功告成!!
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。